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MOTION ESTIMATION METHOD 

Related Applications 

This application claims priority from U.S. Provisional Application No. 
60/221,553, filed on July 28, 2000, and claims priority from Korean Patent 
Application No. 00-56150, filed on September 25, 2000. Both the Provisional 
Application and the Korean Patent Application are incorporated herein by reference 
for all purposes. 

Field of the Invention 

The present invention relates to a motion estimation method, and more 
particularly, to a motion estimation method that enables motion to be estimated with 
relatively low computational complexity. 

Background of the Invention 

In order to effectively encode motion picture data via high-compression 
coding techniques, four kinds of redundancies must be removed from the data. First, 
redundancy in signal constituents must be removed. Second, statistical redundancy, 
which results from the statistical probability of data generation, must be removed. 
Third, time redundancy between frames of the motion picture data must be removed. 
Fourth, spatial redundancy existing within the frames of the motion picture data must 
be removed. 

The redundancy existing in the signal constituents can be reduced by using a 
signal having a brightness to chromaticity ratio of 2: 1 . Also, the statistical 
redundancy can be reduced via a variable length coding technique which uses the 




probability of data generation during the coding process to reduce the average number 
of bits of the data. In addition, the spatial redundancy can be reduced by performing 
discrete cosine transformation ("DCT") techniques. Finally, the time redundancy, 
which is substantially contained in the moving pictures, can be reduced by motion 
estimation ("ME") and motion compensation ("MC"). 

In one motion estimation method, a full search method ("FSM") is used as a 
block-matching algorithm to reduce the time redundancy. However, when the method 
is used as a block-matching algorithm, the complexity of an encoder for encoding the 
motion picture data depends on a motion estimation algorithm. Thus, although this 
method is capable of highly compressing the motion picture data during the encoding 
process, the overall performance of the encoder implementing the FSM is low 
because the block-matching algorithm is extremely complex. 

In another motion estimation method, the complexity of the block-matching 
algorithm is decreased by performing a three-step search ("3SS") or a four-step search 
("4SS"). Such types of methods are well-known and will not be described in detailed 
for the sake of brevity. In such methods, the algorithm analyzes a current block and 
searches for a block which is the mpst similar to the current block by comparing the 
current block with all blocks within a fixed search region. The 3SS method and the 
4SS method can estimate motion with a relatively low degree of complexity. 
However, in order to increase the speed at which motion can be estimated, a motion 
estimation method that is capable of performing a block matching routine even more 
quickly is needed. Accordingly, a block matching algorithm that is even less complex 
than the 3SS method and the 4SS method is required. 

Summary of the Invention 
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One objective of the present invention to provide a motion estimation method 
and program that overcome the problems of the prior art. 

Another objective of the present invention to provide a motion estimation 
method and program which can perform fast block matching by reducing 
computational complexity. 

In order to overcome the above and other objects, a motion estimation method 
is provided. The method comprises: (a) calculating respective mean difference values 
for a current search point of a search block and neighboring search points within the 
search block; (b) performing motion estimation around the current search point if the 
mean difference value of the current search point is smaller than the mean difference 
values of the neighboring search points; and (c) performing motion estimation based 
on the mean difference values of at least some of the neighboring search points if the 
mean difference value of the current search point is not smaller than the mean 
difference values of at least one the neighboring search points. 

In order to further overcome the above and other objects, a software program 
for performing the motion estimation method is provided. 

Brief Description of the Drawing s 

The above objectives and advantages of the present invention will become 
more apparent by describing in detail a preferred embodiment thereof with reference 
to the attached drawings, in which: 

Fig. 1 A is a flowchart illustrating a portion of a motion estimation method 
according to an illustrative embodiment of the present invention; 

Fig. IB is a flowchart illustrating a portion of a motion estimation method 

according to the illustrative embodiment of the present invention; 
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Fig. 1C is a flowchart illustrating a portion of a motion estimation method 
according to the illustrative embodiment of the present invention; 

Fig. ID is a flowchart illustrating a portion of a motion estimation method 
according to the illustrative embodiment of the present invention; 

Fig. IE is a flowchart illustrating a portion of a motion estimation method 
according to the illustrative embodiment of the present invention; 

Fig. IF is a flowchart illustrating a portion of a motion estimation method 
according to the illustrative embodiment of the present invention; 

Fig. 1G is a flowchart illustrating a portion of a motion estimation method 
according to the illustrative embodiment of the present invention; 

Fig. 1H is a flowchart illustrating a portion of a motion estimation method 
according to the illustrative embodiment of the present invention; 

Fig. II is a flowchart illustrating a portion of a motion estimation method 
according to the illustrative embodiment of the present invention; 

Fig. 1 J is a flowchart illustrating a portion of a motion estimation method 
according to the illustrative embodiment of the present invention; 

Fig. 2A illustrates a motion vector distribution of an image sequence for "Car 
Phone" having a quadrature common intermediate format; 

Fig. 2B illustrates a motion vector distribution of an image sequence for 
"Foreman" having the quadrature common intermediate format; 

Fig. 2C illustrates a motion vector distribution of an image sequence for 
"Mom & Daughter" having the quadrature common intermediate format; 

Fig. 2D illustrates a motion vector distribution of an image sequence for 
"Susie" having a quadrature common intermediate format; 
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Fig. 3 illustrates an example of determining search points according to the 
illustrative embodiment of the present invention; 

Fig. 4A illustrates an example in which eight search points are determined on 
test images "Carphone" and "Mom & Daughter"; 

Fig. 4B illustrates an example of resultant calculations of average MAD values 
at corresponding search points for the test image "Carphone"; 

Fig. 4B illustrates an example of resultant calculations of average MAD values 
at corresponding search points for the test image "Mom & Daughter"; and 

Fig. 5 illustrates an example of estimating a motion vector. 

Detailed Description of the Preferred Embodiments 

The following description of the preferred embodiments discloses specific 
configurations, components, and operations. However, the preferred embodiments 
are merely examples of the present invention, and thus, the specific features described 
below are merely used to more easily describe such embodiments and to provide an 
overall understanding of the present invention. Accordingly, one skilled in the art 
will readily recognize that the present invention is not limited to the specific 
embodiments described below. Furthermore, the descriptions of various 
configurations, components, and operations of the present invention that are known to 
one skilled in the art are omitted for the sake of clarity and brevity. 

Figs. 1 A-l J is a flowchart showing various operations of a motion estimation 
method according to an illustrative, non-limiting embodiment of the present 
invention. Such embodiment corresponds to three-step motion estimation operation. 

As a preliminary matter, the motion estimation method assumes that frames of 

a moving picture can be represented by a particular coordinate system (e.g. an x-y 
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coordinate system). In addition, the method assumes that a certain percentage (e.g. 
about 70%) of a motion vector is concentrated on a particular motion vector 
coordinate (e.g. the coordinate (0,0)) of the coordinate system and that the moving 
picture generates frames at a certain rate (e.g. 20-30 frames per second). Figs. 2A-2D 
show examples of vector distributions of four quadrature common intermediate 
formats ("QCIF") for "Carphone " "Foreman," "Mom & Daughter," and "Susie" in 
image sequence. As shown in Figs. 2A-2D, the motion vector distributions are 
concentrated around the coordinate (0,0). 

In addition, the present embodiment of the motion estimation method 
considers a correlation between search points. In particular, the embodiment assumes 
that most motion vectors tend to migrate towards a coordinate at which the 
predetermined mean square difference ("MSD") or a mean absolute difference 
("MAD") is minimized. Specifically, an arbitrary search point is determined, and if 
such point has a minimum MSD or MAD, the point is determined as the coordinate 
for the motion vector. On the other hand, if the arbitrary point does not have the 
minimum MSD or MAD, correlations between the arbitrary point and neighboring 
search points are determined based on the MSD or MAD values of the points. 
Specifically, the difference between the MAD values of the arbitrary search point and 
a first neighboring search point is determined as a first correlation, and the difference 
between the MAD values of the arbitrary search point and a second neighboring 
search point is determined as a second correlation. Then, according to the illustrative 
embodiment, the method determines that motion generally exists in the direction of 
the first neighboring search point if the first correlation is smaller than the second 
correlation. Conversely, the method determines that motion generally exists in the 

direction of the second neighboring search point if the second correlation is smaller 
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than the first correlation. Since determining the MSD or MAD values of various 
search points and determining which of the MSD or MAD values are a minimum 
value is relatively simple, the computational complexity required to implement the 
present embodiment is relatively simple. 

In the present embodiment of the invention, the correlation between two 
search points is determined based on the difference between the MAD or MSD values 
of the two points. However, the present invention is not limited to such a 
configuration, and the correlation between two points can clearly be determined based 
on other relationships between the points or in other manners. 

In the present embodiment shown in Fig. 1 A, the motion estimation method 
determines an initial search point. (Operation 100). In one non-limiting, 
implementation of the method, the initial search point constitutes a center search point 
that is located at the center a search region with the frames of a moving picture. As 
shown in Fig. 3, the center of the search region is located at the coordinate (0,0), and 
thus, the initial search center point is the point located at such coordinate (0,0). 

Then, "x" points located "y" pixels from the search center point (0,0) are 
identified. (Operation 102). In one implementation of the method, "x" and "y" equal 
four, and as shown in Fig. 3, the method identifies four points "a", "b", "c", and "d" 
respectively located four pixels from the search center point (0,0). In other words, in 
such implementation, the points "a", "b", "c", and "d" are respectively located at 
coordinates (-4,-4), (4,-4), (4,4), and (-4,4). After the points "a" to "d" are identified, 
the MAD values of the points "a" to "d" and the center point (0,0) are calculated, and 
the method determines if the MAD value of the center point (0,0) is the smallest 
MAD value. (Operations 104 and 106). 
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If the MAD value of the center point (0,0) is the smallest, "a" points located 
"b" pixels from the search center point (0,0) are identified. (Operation 108). In one 
implementation of the method, "a" equals eight, "b" equals one, and as shown in Fig. 
3, the method identifies eight points respectively located one pixel from the search 
center point (0,0). In other words, in such implementation, the eight points are 
respectively located at coordinates (-1,-1), (0,-1), (1,-1), (1>0), (1,1), (0,1), (-1,1), and 
(-1,0). After the eight points are identified, the MAD values of the points are 
calculated. (Operation 110). Then, the method determines which point of the eight 
points and the center point (0,0) has the smallest MAD value and selects such point as 
the point of the motion vector. (Operation 112). 

On the other hand, as shown in Fig. IB, if the MAD value of the center point 
(0,0) is not the smallest in operation 106, the point a, b, c, or d having the smallest 
MAD value is selected as the new center point. (Operation 1 14). Then, a first value 
is determined based on the new center point and a first point that is adjacent to the 
center point (i.e. a first neighboring point). (Operation 1 16). Similarly, a second 
value is determined based on the new center point and a second point that is adjacent 
to the center point (i.e. a second neighboring point). (Operation 118). 

An illustrative example of the selecting the new center point, the first and 
second neighboring points, and the first and second values will be described in 
conjunction with Figs. 4A and 4B. As shown in Fig. 4B, the MAD value of the point 
"d" (i.e. 1399) is smaller than the MAD values of the points "a" to "c". Accordingly, 
the point "d" is selected as the new center point. Furthermore, since the point "b" and 
"c" are the two points that are the closest to the point "d", they are selected as the first 
and second neighboring points, respectively. Then, the first value is determined by 



8 



calculating the absolute difference between the MAD value of the center point "d" 
and the MAD value of the first neighboring point "b": 



Similarly, the second value is determined by calculating the absolute difference 
between the MAD value of the center point "d" and the MAD value of the second 
neighboring point "c": 



Another illustrative example of the selecting the new center point, the first and 
second neighboring points, and the first and second values will be described in 
conjunction with Figs. 4A and 4C. As shown in Fig. 4C, the MAD value of the point 
"a" (i.e. 1928) is smaller than the MAD values of the points "b" to "d" Accordingly, 
the point "a" is selected as the new center point. Furthermore, since the point "c" and 
"b" are the two points that are the closest to the point "a", they are selected as the first 
and second neighboring points, respectively. Then, the first value is determined by 
calculating the absolute difference between the MAD value of the center point "a" 
and the MAD value of the first neighboring point "c": 



|MAD(d)-MAD(b)| = |1399-1430| = 31 



|MAD(d)-MAD(c)I = |1399-1426| = 27 



|MAD(a)-MAD(c)| = 1 1 928-1 95 1| = 23 
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Similarly, the second value is determined by calculating the absolute difference 
between the MAD value of the center point "a" and the MAD value of the second 
neighboring point "b": 



|MAD(a)-MAD(b)| = |1 928-2 106| = 178 



After the first and second values are determined in operations 116 and 118, the 
method determines if the first value equals the second value. (Operation 120). If the 
first value equals the second value, "c" points located "d" pixels from the search 
center point are identified. (Operation 122). In one implementation of the method, 
"c" equals eight, "d" equals one, and the method identifies eight points respectively 
located one pixel from the center point. After the eight points are identified, the 
MAD values of the points are calculated. (Operation 124). Then, the method 
determines which point of the eight points and the center point has the smallest MAD 
value and selects such point as the point of the motion vector. (Operation 126). 

For example, if the point "c" shown in Fig. 3 is the search center point and the 
first value (i.e. |MAD(c)-MAD(d)|) equals the second value (i.e. |MAD(c)-MAD(a)|), 
the MAD values of eight points located at the coordinates (-5,3), (-4,3), (-3,3), (-3,4), 
(-3,5), (-4,5), (-5,5), and (-5,4) are determined. Then, the point having the smallest 
MAD value from among the points at the coordinates (-5,3), (-4,3), (-3,3), (-3,4), (- 
3,5), (-4,5), (-5,5), and (-5,4) and point "c" (i.e. the coordinate (-4,4)) is selected as 
the motion vector point. 

On the other hand, as shown in Fig. 1 C, if the first value does not equal the 

second value in operation 120, the method determines if the first value is greater than 

the second value. (Operation 128). If the first value is greater than the second value, 
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a selected point between the center point and the second neighboring point is 
identified, and the MAD value of the selected point is determined. (Operations 130 
and 132). On the other hand, if the first value is less than the second value, a selected 
point between the center point and the first neighboring point is identified, and the 
MAD value of the selected point is determined. (Operations 131 and 132). In one 
implementation of the present embodiment, the selected point is a midpoint between 
the center point and the first or second neighboring point. 

For example, as shown in Fig. 4B, the first value (i.e. |MAD(d)-MAD(b)|) 
equals 31, and the second value (i.e. |MAD(d)-MAD(c)|) equals 27. Thus, the first 
value is greater than the second value. As a result, the midpoint "dc" between the 
center point "d" and the second neighboring point "c" is identified, and the MAD 
value of the midpoint "dc" is determined. Also, as shown in Fig. 4C, the first value 
(i.e. |MAD(a)-MAD(c)|) equals 23, and the second value (i.e. |MAD(a)-MAD(b)|) 
equals 178. Thus, the first value is less than the second value. As a result, the 
midpoint "ca" between the center point "a" and the first neighboring point "c" is 
identified, and the MAD value of the midpoint "ca" is determined. 

Once the MAD value of the midpoint is determined in operation 132, the 

method determines if the MAD value of the midpoint equals the MAD value of the 

center point. (Operation 134). As shown in Fig. ID, if the MAD value of the 

midpoint equals the MAD value of the center point, an intermediate point between the 

midpoint and the center point is identified. (Operation 136). Then, "e" points located 

"f ' pixels from the intermediate point are identified. (Operation 138). In one 

implementation of the method, "e" equals eight, "f ' equals one, and the method 

identifies eight points respectively located one pixel from the intermediate point. 

After the eight points are identified, the MAD values of the eight points and the 
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intermediate point are calculated. (Operation 140). Then, the method determines 
which point of the eight points and the intermediate point has the smallest MAD value 
and selects such point as the point of the motion vector. (Operation 142). 

For example, in Fig. 4A, assume that the point "a" is the center point and the 
point "ab" is the midpoint. Also, assume that the MAD value of the midpoint "ab" 
equals the MAD value of the center point "a" in operation 134. In such a scenario, an 
intermediate point between the midpoint "ab" and the center point "a" is identified in 
operation 136. In one example of the present embodiment, the intermediate point is a 
midpoint between the center point "a" and the midpoint "ab". In other words, the 
intermediate point is the point located at the coordinate (-2,-4) in Fig. 4A. Then, in 
operation 138, eight points (-3,-5), (-2,-5), (-1,-5), (-1,-4), (-1,-3), (-2,-3), (-3,-3), and 
(-3,-4) located one pixel from the intermediate point (-2,-4) are identified. Finally, in 
operation 142, the method determines which point of the eight points and intermediate 
point has the smallest MAD value and selects such point as the point of the motion 
vector. 

On the other hand, as shown in Fig. IE, if the MAD value of the midpoint 
does not equals the MAD value of the center point in operation 134, the method 
determines if the MAD of the center point is greater than the MAD of the MAD of the 
midpoint. (Operation 144). If the MAD of center point is greater than the MAD of 
the midpoint, the midpoint is selected as the new center point, and "g" points located 
"h" pixels from the new center point are determined. (Operations 146 and 150). In 
contrast, if the MAD of center point is less than the MAD of the midpoint, "g" points 
located "h" pixels from the current center point are determined. (Operation 150). In 
one example of the present embodiment, "g" equals four, "h" equals two, and four 
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points located two pixels from the center point are determined. Then, the MAD 
values of the four points are determined. (Operation 152). 

For example, as shown in Fig. 4B, the MAD value of the center point "d" (i.e. 
1399) is greater than the MAD value of the midpoint "dc" (i.e. 1 108). Thus, in 
operation 146, the midpoint "dc" is selected as the new center point, and four points 
located two pixels from the new center point are determined. For example, in Fig. 3, 
the four points located at coordinates (-2,2), (2,2), (2,6), and (-2,6) are selected. 
Afterwards, in operation 152, the MAD values of the four points are determined. 

After the MAD values of the four points are determined in operation 152, the 
method determines if the MAD of the center point is smaller than all of the MAD 
values of the four points. (Operation 153). If the MAD value of the center point is 
the smallest, "i" points located "j" pixels from the center point are identified. 
(Operation 154). In one implementation of the method, "i" equals eight, "j" equals 
one, and the method identifies eight points respectively located one pixel from the 
center point. After the eight points are identified, the MAD values of the eight points 
are calculated. (Operation 156). Then, the method determines which point of the 
eight points and the center point has the smallest MAD value and selects such point as 
the point of the motion vector. (Operation 158). 

For instance, in the previous example, the center point is the point "dc", and 

the four points (-2,2), (2,2), (2,6), and (-2,6) surrounding the center point "dc" were 

identified. If the MAD value of the center point "dc" is smaller than the MAD values 

of the points (-2,2), (2,2), (2,6), and (-2,6) in operation 153, eight points located one 

pixel away from the center point "dc" are identified in operation 154. As shown in 

Fig. 4A, the eight points are located at the coordinates (-1,3), (0,3), (1,3), (1,4), (1,5), 

(0,5), (-1,5), and (-1,4). Afterwards, the point of the eight points and the center point 
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"dc" point having the smallest MAD value is selected as the point of the motion 
vector in operation 158. 

On the other hand, if the MAD value of the center point is not smaller than the 
MAD values of the four points in operation 153, the method determines which of the 
four points has the smallest MAD value, and selects such point as a new center point. 
(Operation 160). Then, a first value is determined based on the new center point and 
a first point that is adjacent to the center point (i.e. a first neighboring point). 
(Operation 162). Similarly, a second value is determined based on the new center 
point and a second point that is adjacent to the center point (i.e. a second neighboring 
point). (Operation 163). The first and second values calculated in operations 162 and 
163 may or may not be analogous to the first and second values calculated in 
operations 116 and 118. 

Again, using the previous example, the center point is the point "dc" shown in 
Fig. 4A, and the four points (-2,2), (2,2), (2,6), and (-2,6) surround the center point 
"dc". If the MAD value of the center point "dc" is not smaller than all of the MAD 
values of the four points (-2,2), (2,2), (2,6), and (-2,6) in operation 153, a point of the 
four points (-2,2), (2,2), (2,6), and (-2,6) having the smallest MAD value is selected as 
the new center point in operation 160. For instance, if the MAD value of the point 
(2,6) is smaller than the all of the MAD values of the points (-2,2), (2,2), and (-2,6), 
the point (2,6) is selected as the new center point. 

Furthermore, since the points (2,2) and (-2,6) are the two points that are the 

closest to the center point (2,6), they are selected as the first and second neighboring 

points, respectively. As a result, in operation 162, the first value is determined by 

calculating the absolute difference between the MAD value of the center point (2,6) 

and the MAD value of the first neighboring point (2,2): 
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|MAD(2,6)-MAD(2,2)| 

Similarly, in operation 163, the second value is determined by calculating the absolute 
difference between the MAD value of the center point (2,6) and the MAD value of the 
second neighboring point (-2,6): 

|MAD(2,6)-MAD(-2,6)| 

After the first and second values are calculated, the method determines if the 
first and second values are equal. (Operation 164). Then, as shown in Fig. 1G, if the 
first value equals the second value, "k" points located "1" pixels from the center point 
are identified. (Operation 166). In one implementation of the method, "k" equals 
eight, "1" equals one, and the method identifies eight points respectively located one 
pixel from the center point. After the eight points are identified, the MAD values of 
the points are calculated. (Operation 168). Then, the method determines which point 
of the eight points and the center point has the smallest MAD value and selects such 
point as the point of the motion vector. (Operation 170). 

For example, in the previous example, if the point (2,6) is the center point and 
the first value (i.e. |MAD(2,6)-MAD(2,2)|) equals the second value (i.e. |MAD(2,6)- 
MAD(-2,6)|), the eight points located at the coordinates (1,5), (2,5), (3,5), (3,6), (3,7), 
(2,7), (1,7), and (1,6) are identified in operation 166. Then, the point having the 
smallest MAD value from among the points at the coordinates (1,5), (2,5), (3,5), (3,6), 
(3,7), (2,7), (1,7), and (1,6) and the center point (2,6) is selected as the motion vector 
point in operations 168 and 170. 
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On the other hand, as shown in Fig. 1H, if the first value does not equal the 
second value in operation 164, the method determines if the first value is greater than 
the second value. (Operation 172). If the first value is greater than the second value, 
a selected point between the center point and the second neighboring point is 
identified, and the MAD value of the selected point is determined. (Operations 173 
and 176). On the other hand, if the first value is less than the second value, a selected 
point between the center point and the first neighboring point is identified, and the 
MAD value of the selected point is determined. (Operations 174 and 176). Again, as 
discussed above, the selected point may be a midpoint between the center point and 
the first or second neighboring point or some other point between the center point and 
the first or second neighboring point. 

In the previous example discussed in conjunction with Fig. 4A, the center 
point is the point (2,6), the first neighboring point is the point (2,2), the second 
neighboring point is the point (-2,6), the first value equals |MAD(2,6)-MAD(2,2)|, and 
the second value equals |MAD(2,6)-MAD(-2,6)|. If the first value |MAD(2,6)- 
MAD(2,2)| is greater than the second value |MAD(2,6)-MAD(-2,6)| in operation 172, 
the midpoint (0,6) between the center point (2,6) and the second neighboring point (- 
2,6) is identified, and the MAD value of the midpoint (0,6) is determined in 
operations 173 and 176. On the other hand, if the first value |MAD(2,6)-MAD(2,2)| is 
less than the second value |MAD(2,6)-MAD(-2,6)| in operation 172, the midpoint 
(2,4) between the center point (2,6) and the first neighboring point (2,2) is identified, 
and the MAD value of the midpoint (2,4) is determined in operations 174 and 176. 

Once the MAD value of the midpoint is determined in operation 1 76, the 

method determines if the MAD value of the midpoint equals the MAD value of the 

center point. (Operation 178). As shown in Fig. II, if the MAD value of the midpoint 
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equals the MAD value of the center point, an intermediate point between the midpoint 
and the center point is identified. (Operation 180). Then, "m" points located "n" 
pixels from the intermediate point are identified. (Operation 182). In one 
implementation of the method, "m" equals eight, "n" equals one, and the method 
identifies eight points respectively located one pixel from the intermediate point. 
After the eight points are identified, the MAD values of the eight points and the 
intermediate point are calculated. (Operation 184). Then, the method determines 
which point of the eight points and the intermediate point has the smallest MAD value 
and selects such point as the point of the motion vector. (Operation 186). 

For example, in the previous example discussed above in conjunction with 
Fig. 4A, the point (2,6) is the center point and the point (0,6) is the midpoint. If the 
MAD value of the midpoint (0,6) equals the MAD value of the center point (2,6) in 
operation 178, an intermediate point between the midpoint (0,6) and the center point 
(2,6) is identified in operation 180. As mentioned above, the intermediate point may 
be a midpoint between the center point (2,6) and the midpoint (0,6). In such a 
scenario, the intermediate point is the point (1,6) shown in Fig. 4 A. Then, in 
operation 182, eight points (0,5), (1,5), (2,5), (2,6), (2,7), (1,7), (0,7), and (0,6) 
located one pixel from the intermediate point (1,6) are identified. Finally, in 
operation 1 86, the method determines which point of the eight points and intermediate 
point has the smallest MAD value and selects such point as the point of the motion 
vector. 

On the other hand, as shown in Fig. 1 J, if the MAD value of the midpoint does 

not equal the MAD value of the center point in operation 178, the method determines 

if the MAD of the center point is greater than the MAD of the midpoint. (Operation 

188). If the MAD of center point is greater than the MAD of the midpoint, the 
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midpoint is selected as the new center point, and "o" points located "p" pixels from 
the new center point are determined. (Operations 190 and 192). In contrast, if the 
MAD of center point is less than the MAD of the midpoint, "o" points located "p" 
pixels from the current center point are determined. (Operation 150). In one example 
of the present embodiment, "o" equals eight, "p" equals one, and eight points located 
one pixel from the center point are determined. Then, the MAD values of the eight 
points are determined. (Operation 194). Then, the method determines which point of 
the eight points and the center point has the smallest MAD value and selects such 
point as the point of the motion vector. (Operation 196). 

Continuing with the example discussed above in conjunction with Fig. 4A, if 
the MAD value of the center point (2,6) is greater than the MAD value of the 
midpoint (0,6) in operation 188, the midpoint (0,6) is selected as the new center point 
in operation 190. Then, eight points located one pixel from the center point (0,6) are 
determined. For example, in Fig. 4A, the eight points located at coordinates (-1,5), 
(0,5), (1,5), (1,6), (1,7), (0,7), (-1,7), and (-1,6) may be selected. Afterwards, in 
operation 194, the MAD values of the eight points are determined, and point (0,6), (- 
1,5), (0,5), (1,5), (1,6), (1,7), (0,7), (-1,7), and (-1,6) having the smallest MAD value 
is selected as the point of the motion vector in operation 196. 

Fig. 5 illustrates a complete example of estimating a motion vector in 
accordance with the present embodiment shown in Figs. 1 A-1J. As shown in the 
figure, the center "o" of a 15 pixel x 15 pixel search region is identified, and four 
points "a", "b", "c", and "d" located two pixels from the center point "o" are 
identified. (Operations 100 and 102). Then, the method calculates the MAD values 
of the points "a", "b", "c", "d", and "o" and determines that the point "d" has the 
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smallest MAD value. (Operations 104 and 106). Accordingly, the point "d" is 
selected as the new center point. (Operation 114). 

Subsequently, a first value |MAD(d)-MAD(b)| is determined based on the 
center point "d" and a first neighboring point "b", and a second value |MAD(d)- 
MAD(c)| is determined based on the center point "d" and a second neighboring point 
"c". (Operations 116 and 1 1 8). In the present example, the first value |MAD(d)- 
MAD(b)| is less than the second value |MAD(d)-MAD(c)|, and thus, a midpoint "e" 
between the center point "d" and the first neighboring point "b" is determined, and the 
MAD value of the midpoint "e" is calculated. (Operations 120, 128, 131 and 132). 

Furthermore, in the present example, the MAD value of the center point "d" is 
greater than the MAD value of the midpoint "e'\ and thus, the midpoint "e" is 
selected as a new center point. (Operations 134, 144, and 146). Then, four points "f \ 
"g", "h", and "i" located two pixels away from the center point "e" are identified, and 
the MAD values of the points "f ', "g", "h" and "i" are determined. (Operations 150 
and 152). In the present example, the MAD value of the point "i" is smaller than the 
MAD values of the points "e", "f \ "g", and "h", and thus, the point "i" is selected as 
the new center point. (Operations 153 and 160). 

Afterwards, a first value |MAD(i)-MAD(g)| is determined based on the center 
point "i" and a first neighboring point "g", and a second value |MAD(i)-MAD(h)| is 
determined based on the center point "i" and a second neighboring point "h". 
(Operations 162 and 163). In the present example, the first value |MAD(i)-MAD(g)| 
is less than the second value |MAD(i)-MAD(h)|, and thus, a midpoint "j" between the 
center point "i" and the first neighboring point "g" is determined. (Operations 164, 
172, and 174). Then, the MAD value of the midpoint "j" is calculated. (Operation 
176). 
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In the present example, the MAD value of the center point "i" is greater than 
the MAD value of the midpoint "j", and thus, the midpoint "j" is selected as a new 
center point. (Operations 178, 188, and 190). Then, eight points (5,1), (6,1), (7,1), 
(7,0), (7,-1), (6,-1), (5,-1), and (5,0) located one pixel away from the center point "j" 
are identified, and the MAD values of the points (5,1), (6,1), (7,1), (7,0), (7,-1), (6,-1), 
(5,-1), and (5,0) are determined. (Operations 192 and 194). Since the MAD value of 
the point (7,1) is smaller than the MAD values of the points (5,1), (6,1), (7,0), (7,-1), 
(6,-1), (5,-1), and (5,0), the point (7,1) is selected as the point of the motion vector. 
(Operation 196). In other words, the motion vector is defined from the point "o" to 
the point (7,1). 

A test experiment was performed to evaluate the performance of conventional 
motion estimation methods and the motion estimation method of the present 
embodiment. The conventional methods included a full search method ("FSM"), 
which estimates motion with the highest precision, a three- step search ("3SS"), which 
estimates motion relatively fast, and a four-step search ("4SS"), which has become 
recently recognized as having good performance. An average search point ("ASP") 
per macro block is chosen as a reference for comparing the computational complexity 
of the various methods, and the results of such comparison is illustrated in Table 1. 



Table 1 





Car Phone 


Foreman 


Mom & 
Daughter 


Susie 


FSM 


225 


225 


225 


225 


3SS 


25 


25 


25 


25 


4SS 


17.0249 


17.2818 


17.0039 


17.5189 


Present 
Invention 


13.6019 


13.6512 


13.2085 


13.5189 
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Referring to Table 1 , the motion estimation method of the present embodiment has a 
smaller ASP per macro block than the conventional motion estimation methods (i.e. 
FSM, 3SS, 4SS). Thus, the present embodiment remarkably reduces computational 
complexity of estimating motion and enhances image compression speed. 

Also, PSNR, which is expressed in decibels ("db"), is used as a reference for 
comparing the precision of the various motion estimation methods. Table 2 shows the 
results of measuring the average PSNR for 1 00 frames of a test image evaluated using 
each of the methods. 



Table 2 





Car Phone 


Foreman 


Mom & 
Daughter 


Susie 


FSM 


32.1984 


30.619 


37.4603 


35.3273 


3SS 


31.9917 


30.2156 


37.3863 


35.0973 


4SS 


31.9952 


30.2805 


37.3922 


35.0892 


Present 
Invention 


31.9009 


30.3276 


37.3896 


34.9263 



Referring to Table 2, the motion estimation method of the present embodiment does 
not substantially deteriorate the quality of pictures during the image compression 
process in comparison to the conventional motion estimation methods (i.e. FSM, 3SS, 
4SS). 

Also, in the present embodiment discussed above, the method estimated 
motion by analyzing the MAD values of various points. However, the present 
invention is not limited to such an analysis, and other techniques for estimating 
motion may be used. For example, the method may analyze the MSD values in a 
manner that is similar to the manner in which the MAD values are analyzed. 
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In addition, the motion estimation method of the present invention can be 
incorporated into a software program that is executed by a processor. The software 
program may be supplied to the processor via a read only memory ("ROM"), a 
random access memory ("RAM"), a floppy disk, a hard disk, an optical disk, a carrier 
wave (e.g. a carrier wave transmitted via the internet, a vertical blanking interval of a 
television signal, etc.), or any other computer readable medium. In addition, the 
processor may be contained within a personal computer, a server computer, or any 
other type of processing machine. 

The previous description of the preferred embodiments is provided to enable a 
person skilled in the art to make and use the present invention. Moreover, various 
modifications to these embodiments will be readily apparent to those skilled in the art, 
and the generic principles and specific examples defined herein may be applied to 
other embodiments without the use of inventive faculty. For instance, the above 
embodiments refer to parameters and coordinates that have specific values and refer 
to specific operations that are performed. However, the present invention is not 
limited to such parameters and coordinates having such values and is not limited to 
the specific operations performed above. Furthermore, many of the operations 
illustrated above may be deleted or performed in many different sequences. In 
addition, upon reading the present application, one skilled in the art clearly would 
know how to incorporate other operations into the method disclosed above without 
the use of inventive faculty. Therefore, the present invention is not intended to be 
limited to the embodiments described herein but is to be accorded the widest scope as 
defined by the limitations of the claims and equivalents thereof. 
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